package com.bookool.myboot.common.config;

import com.github.pagehelper.PageHelper;

import org.mybatis.spring.boot.autoconfigure.ConfigurationCustomizer;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.Properties;

/**
 * Mybatis配置
 *
 * @author Tommy
 */
@Configuration
@EnableAutoConfiguration
public class MybatisConfiguration {
    @Bean
    ConfigurationCustomizer mybatisConfigurationCustomizer() {
        return configuration -> {
            // 在null时也调用 setter,适应于返回Map,3.2版本以上可用
            configuration.setCallSettersOnNulls(true);
            // 数据库中下划线自动转驼峰命名
            configuration.setMapUnderscoreToCamelCase(true);
        };
    }

    @Bean
    public PageHelper pageHelper() {
        PageHelper pageHelper = new PageHelper();

        // 添加配置，也可以指定文件路径
        Properties p = new Properties();

        // 该参数默认为false
        // 设置为true时，会将RowBounds第一个参数offset当成pageNum页码使用
        // 和startPage中的pageNum效果一样
        p.setProperty("offsetAsPageNum", "false");

        // 该参数默认为false
        // 设置为true时，使用RowBounds分页会进行count查询
        p.setProperty("rowBoundsWithCount", "false");

        // 3.3.0版本可用 - 分页参数合理化，默认false禁用
        // 启用合理化时，如果pageNum<1会查询第一页，如果pageNum>pages会查询最后一页
        // 禁用合理化时，如果pageNum<1或pageNum>pages会返回空数据
        p.setProperty("reasonable", "false");

        pageHelper.setProperties(p);

        return pageHelper;

        /*
        <configuration>
            <plugins>
                <plugin interceptor="com.github.pagehelper.PageHelper">
                    <!--指明数据库 4.0.0以后不需要设置此属性-->
                    <property name="dialect" value="mysql"/>
                    <!-- 该参数默认为false -->
                    <!-- 设置为true时，会将RowBounds第一个参数offset当成pageNum页码使用 -->
                    <!-- 和startPage中的pageNum效果一样-->
                    <property name="offsetAsPageNum" value="true"/>
                    <!-- 该参数默认为false -->
                    <!-- 设置为true时，使用RowBounds分页会进行count查询 -->
                    <property name="rowBoundsWithCount" value="true"/>
                    <!-- 设置为true时，如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果 -->
                    <!-- （相当于没有执行分页查询，但是返回结果仍然是Page类型）-->
                    <property name="pageSizeZero" value="true"/>
                    <!-- 3.3.0版本可用 - 分页参数合理化，默认false禁用 -->
                    <!-- 启用合理化时，如果pageNum<1会查询第一页，如果pageNum>pages会查询最后一页 -->
                    <!-- 禁用合理化时，如果pageNum<1或pageNum>pages会返回空数据 -->
                    <property name="reasonable" value="true"/>
                    <!-- 3.5.0版本可用 - 为了支持startPage(Object params)方法 -->
                    <!-- 增加了一个`params`参数来配置参数映射，用于从Map或ServletRequest中取值 -->
                    <!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,orderBy,不配置映射的用默认值 -->
                    <!-- 不理解该含义的前提下，不要随便复制该配置 -->
                    <property name="params" value="pageNum=start;pageSize=limit;"/>
                    <!-- 支持通过Mapper接口参数来传递分页参数 -->
                    <property name="supportMethodsArguments" value="true"/>
                    <!-- always总是返回PageInfo类型,check检查返回类型是否为PageInfo,none返回Page -->
                    <property name="returnPageInfo" value="check"/>
                </plugin>
            </plugins>
        </configuration>
         */
    }

}
